home *** CD-ROM | disk | FTP | other *** search
/ EnigmA Amiga Run 1996 February / EnigmA AMIGA RUN 04 (1996)(G.R. Edizioni)(IT)[!][issue 1996-02][Skylink CD III].iso / earcd / comm2 / termsorc.lha / Extras / Source / term-source.lha / termPickScreen.c < prev    next >
C/C++ Source or Header  |  1995-09-26  |  6KB  |  302 lines

  1. /*
  2. **    termPickScreen.c
  3. **
  4. **    Simplified public screen selection routine
  5. **
  6. **    Copyright © 1990-1995 by Olaf `Olsen' Barthel
  7. **        All Rights Reserved
  8. */
  9.  
  10. #include "termGlobal.h"
  11.  
  12. enum    {    GAD_LIST=1,GAD_USE,GAD_CANCEL };
  13.  
  14.     /* BuildScreenList():
  15.      *
  16.      *    Build a private copy of the public screen list.
  17.      */
  18.  
  19. STATIC struct List *
  20. BuildScreenList(VOID)
  21. {
  22.     struct List *List,*PubScreenList;
  23.  
  24.         /* Get the list body. */
  25.  
  26.     if(List = (struct List *)AllocVecPooled(sizeof(struct List),MEMF_ANY))
  27.     {
  28.         NewList(List);
  29.  
  30.             /* Get access to the public screen list. */
  31.  
  32.         if(PubScreenList = LockPubScreenList())
  33.         {
  34.             struct Node *Next,*Node;
  35.  
  36.             Node = PubScreenList -> lh_Head;
  37.  
  38.                 /* Scan the list. */
  39.  
  40.             while(Next = Node -> ln_Succ)
  41.             {
  42.                     /* Don't include the current `term' public
  43.                      * screen name in it.
  44.                      */
  45.  
  46.                 if(strcmp(Node -> ln_Name,TermIDString))
  47.                 {
  48.                     struct Node *New = CreateNode(Node -> ln_Name);
  49.  
  50.                         /* Got a new node? */
  51.  
  52.                     if(New)
  53.                         AddTail(List,New);
  54.                 }
  55.  
  56.                 Node = Next;
  57.             }
  58.  
  59.             UnlockPubScreenList();
  60.         }
  61.  
  62.             /* In case the list happens to remain empty,
  63.              * include the Workbench screen in it.
  64.              */
  65.  
  66.         if(!List -> lh_Head -> ln_Succ)
  67.         {
  68.             struct Node *New = CreateNode("Workbench");
  69.  
  70.             if(New)
  71.                 AddTail(List,New);
  72.             else
  73.             {
  74.                 FreeVecPooled(List);
  75.  
  76.                 List = NULL;
  77.             }
  78.         }
  79.     }
  80.  
  81.     return(List);
  82. }
  83.  
  84.     /* PickScreen(STRPTR Name):
  85.      *
  86.      *    Your nice public screen selection routine.
  87.      */
  88.  
  89. BYTE __regargs
  90. PickScreen(struct Window *Window,STRPTR Name)
  91. {
  92.     struct List    *ScreenList;
  93.     BYTE         Result = FALSE;
  94.  
  95.     if(ScreenList = BuildScreenList())
  96.     {
  97.         struct LayoutHandle *Handle;
  98.  
  99.         if(Handle = LT_CreateHandleTags(Window -> WScreen,
  100.             LH_LocaleHook,    &LocaleHook,
  101.         TAG_DONE))
  102.         {
  103.             struct Window    *PanelWindow;
  104.             ULONG         Index = (ULONG)~0,i;
  105.             struct Node    *Node;
  106.             LONG         MaxWidth,MaxHeight,Len;
  107.  
  108.             MaxWidth = MaxHeight = 0;
  109.  
  110.             for(Node = ScreenList -> lh_Head, i = 0 ; Node -> ln_Succ ; Node = Node -> ln_Succ, i++)
  111.             {
  112.                 if(!Stricmp(Node -> ln_Name,Name))
  113.                     Index = i;
  114.  
  115.                 Len = strlen(Node -> ln_Name);
  116.  
  117.                 if(Len > MaxWidth)
  118.                     MaxWidth = Len;
  119.  
  120.                 MaxHeight++;
  121.             }
  122.  
  123.             if(MaxWidth < 30)
  124.                 MaxWidth = 30;
  125.  
  126.             if(MaxHeight < 5)
  127.                 MaxHeight = 5;
  128.             else
  129.             {
  130.                 if(MaxHeight > 20)
  131.                     MaxHeight = 20;
  132.             }
  133.  
  134.             LT_New(Handle,
  135.                 LA_Type,    VERTICAL_KIND,
  136.             TAG_DONE);
  137.             {
  138.                 LT_New(Handle,
  139.                     LA_Type,    VERTICAL_KIND,
  140. //                    LA_LabelID,    MSG_V36_1271,
  141.                 TAG_DONE);
  142.                 {
  143.                     LT_New(Handle,
  144.                         LA_Type,    LISTVIEW_KIND,
  145. /*                        LA_LabelID,    MSG_TERMPICKSCREEN_SCREEN_LIST_GAD,*/
  146.                         LA_Chars,    30,
  147.                         LA_ID,        GAD_LIST,
  148.                         LA_Lines,    5,
  149.                         LALV_MaxGrowX,    MaxWidth,
  150.                         LALV_MaxGrowY,    MaxHeight,
  151.                         LALV_ResizeY,    TRUE,
  152.                         GTLV_Labels,    ScreenList,
  153.                         GTLV_Selected,    Index,
  154.                         LALV_Link,    NIL_LINK,
  155.                         LALV_CursorKey,    TRUE,
  156.                     TAG_DONE);
  157.  
  158.                     LT_EndGroup(Handle);
  159.                 }
  160.  
  161.                 LT_New(Handle,
  162.                     LA_Type,VERTICAL_KIND,
  163.                 TAG_DONE);
  164.                 {
  165.                     LT_New(Handle,
  166.                         LA_Type,    XBAR_KIND,
  167.                         LAXB_FullSize,    TRUE,
  168.                     TAG_DONE);
  169.  
  170.                     LT_EndGroup(Handle);
  171.                 }
  172.  
  173.                 LT_New(Handle,LA_Type,HORIZONTAL_KIND,
  174.                     LAGR_SameSize,    TRUE,
  175.                     LAGR_Spread,    TRUE,
  176.                 TAG_DONE);
  177.                 {
  178.                     LT_New(Handle,
  179.                         LA_Type,    BUTTON_KIND,
  180.                         LA_LabelID,    MSG_GLOBAL_USE_GAD,
  181.                         LA_ID,        GAD_USE,
  182.                         LABT_ReturnKey,    TRUE,
  183.                         LABT_ExtraFat,    TRUE,
  184.                     TAG_DONE);
  185.  
  186.                     LT_New(Handle,
  187.                         LA_Type,    BUTTON_KIND,
  188.                         LA_LabelID,    MSG_GLOBAL_CANCEL_GAD,
  189.                         LA_ID,        GAD_CANCEL,
  190.                         LABT_EscKey,    TRUE,
  191.                         LABT_ExtraFat,    TRUE,
  192.                     TAG_DONE);
  193.  
  194.                     LT_EndGroup(Handle);
  195.                 }
  196.  
  197.                 LT_EndGroup(Handle);
  198.             }
  199.  
  200.             if(PanelWindow = LT_Build(Handle,
  201.                 LAWN_TitleID,        MSG_TERMPICKSCREEN_SCREENS_TXT,
  202.                 LAWN_IDCMP,        IDCMP_CLOSEWINDOW,
  203.                 LAWN_HelpHook,        &GuideHook,
  204.                 LAWN_Parent,        Window,
  205.                 WA_DepthGadget,        TRUE,
  206.                 WA_CloseGadget,        TRUE,
  207.                 WA_DragBar,        TRUE,
  208.                 WA_RMBTrap,        TRUE,
  209.                 WA_Activate,        TRUE,
  210.                 WA_SimpleRefresh,    TRUE,
  211.             TAG_DONE))
  212.             {
  213.                 struct IntuiMessage    *Message;
  214.                 BOOLEAN             Done = FALSE;
  215.                 ULONG             MsgClass;
  216.                 UWORD             MsgCode;
  217.                 struct Gadget        *MsgGadget;
  218.  
  219.                 LT_ShowWindow(Handle,TRUE);
  220.  
  221.                 PushWindow(PanelWindow);
  222.  
  223.                 do
  224.                 {
  225.                     if(Wait(PORTMASK(PanelWindow -> UserPort) | SIG_BREAK) & SIG_BREAK)
  226.                         break;
  227.  
  228.                     while(Message = (struct IntuiMessage *)LT_GetIMsg(Handle))
  229.                     {
  230.                         MsgClass    = Message -> Class;
  231.                         MsgCode        = Message -> Code;
  232.                         MsgGadget    = (struct Gadget *)Message -> IAddress;
  233.  
  234.                         LT_ReplyIMsg(Message);
  235.  
  236.                         if(MsgClass == IDCMP_CLOSEWINDOW)
  237.                             Done = TRUE;
  238.  
  239.                         if(MsgClass == IDCMP_GADGETUP)
  240.                         {
  241.                             switch(MsgGadget -> GadgetID)
  242.                             {
  243.                                 case GAD_USE:
  244.  
  245.                                     if(Index != (ULONG)~0)
  246.                                     {
  247.                                         struct Node *Node = GetListNode(Index,ScreenList);
  248.  
  249.                                         if(Node)
  250.                                         {
  251.                                             strcpy(Name,Node -> ln_Name);
  252.  
  253.                                             Result = TRUE;
  254.                                         }
  255.                                     }
  256.  
  257.                                     Done = TRUE;
  258.                                     break;
  259.  
  260.                                 case GAD_CANCEL:
  261.  
  262.                                     Done = TRUE;
  263.                                     break;
  264.  
  265.                                 case GAD_LIST:
  266.  
  267.                                     Index = MsgCode;
  268.                                     break;
  269.                             }
  270.                         }
  271.  
  272.                         if(MsgClass == IDCMP_IDCMPUPDATE)
  273.                         {
  274.                             struct Node *Node = GetListNode(Index = MsgCode,ScreenList);
  275.  
  276.                             if(Node)
  277.                             {
  278.                                 strcpy(Name,Node -> ln_Name);
  279.  
  280.                                 Done = Result = TRUE;
  281.  
  282.                                 LT_PressButton(Handle,GAD_USE);
  283.                             }
  284.                         }
  285.                     }
  286.                 }
  287.                 while(!Done);
  288.  
  289.                 PopWindow();
  290.             }
  291.  
  292.             LT_DeleteHandle(Handle);
  293.         }
  294.  
  295.         DeleteList(ScreenList);
  296.     }
  297.     else
  298.         DisplayBeep(Window -> WScreen);
  299.  
  300.     return(Result);
  301. }
  302.